01 - Złożoność obliczeniowa algorytmów
Systemy Wbudowane i Przetwarzanie Brzegowe
Politechnika Poznańska, Instytut Robotyki i Inteligencji Maszynowej
Ćwiczenie laboratoryjne 1: Złożoność obliczeniowa algorytmów
Powrót do spisu treści ćwiczeń laboratoryjnych
Analiza złożoności obliczeniowej algorytmów
Wydajność algorytmu obejmuje wiele składowych takich jak np. czas wykonywania, zajętość pamięci, wykorzystanie CPU. Złożoność obliczeniowa jest jednym z najważniejszych czynników, które należy uwzględnić podczas projektowania algorytmu. Jest ona określana jako liczba operacji, które muszą zostać zrealizowane, aby wykonać algorytm. Złożoność obliczeniowa jest zwykle określana przy pomocy notacji duże O, która jest zdefiniowana jako asymptotyczne tempo wzrostu, czyli miara określająca zachowanie wartości funkcji wraz ze wzrostem rozmiaru jej danych wejściowych. Notacja ta określa tempo wzrostu w najgorszym scenariuszu, czyli maksymalną liczbę operacji, które muszą zostać wykonane.
Zadanie 1. Zaimplementuj metodę, która zwraca sumę pierwszej wartości n-elementowej listy podniesionej do drugiej potęgi oraz ostatniej wartości podniesionej do trzeciej potęgi. Zbadaj złożoność obliczeniową algorytmu poprzez przygotowanie wykresu czasu wykonania algorytmu w zależności od n, do pomiaru czasu wykorzystaj perf_counter z biblioteki time. Wykonaj eksperymenty dla n od 2 do 50. Porównaj wyniki z teorią.
Zadanie 2. Zaimplementuj funkcję obliczającą sumę liczb naturalnych od 0 do n. Zbadaj złożoność obliczeniową algorytmu poprzez przygotowanie wykresu czasu wykonania algorytmu w zależności od n, do pomiaru czasu wykorzystaj perf_counter z biblioteki time. Wykonaj eksperymenty dla n od 2 do 50. Porównaj wyniki z teorią.
Zadanie 3. Zaimplementuj algorytm sortowania bąbelkowego dla losowej n-elementowej listy. Zbadaj złożoność obliczeniową algorytmu poprzez przygotowanie wykresu czasu wykonania algorytmu w zależności od n, do pomiaru czasu wykorzystaj perf_counter z biblioteki time. Wykonaj eksperymenty dla n od 2 do 50. Porównaj wyniki z teorią.
Zadanie 4. Zaimplementuj metodę zwracającą n-ty element ciągu Fibonacciego. Zaimplementowana funkcja powinna korzystać z rekurencji. Zbadaj złożoność obliczeniową algorytmu poprzez przygotowanie wykresu czasu wykonania algorytmu w zależności od n, do pomiaru czasu wykorzystaj perf_counter z biblioteki time. Wykonaj eksperymenty dla n od 2 do 40. Porównaj wyniki z teorią.
Zadanie 5. Zaimplementuj algorytm wyszukiwania indeksu elementu w liście przy pomocy drzewa binarnego. Zwróć uwagę, że przedstawiony algorytm wymaga wcześniejszego posortowania wejściowej listy elementów. Zbadaj złożoność obliczeniową algorytmu poprzez przygotowanie wykresu czasu wykonania algorytmu w zależności od n, do pomiaru czasu wykorzystaj perf_counter z biblioteki time. Wykonaj eksperymenty dla n od 2 do 50. Porównaj wyniki z teorią.
Zadanie 6. Przedstaw powyższe wyniki w postaci
wspólnego wykresu i porównaj z poniższym grafem. Na podstawie
charakterystyki przebiegu określ złożoność obliczeniową w postaci
notacji O i dodaj jako etykiętę do wykresu (np. poprzez parametr
label
w funkcji plot
z pakietu matplotlib.pyplot).